对C1FlexGrid for WinForms中指定区域的数据进行排序

在某些特殊情况下,用户需要对C1FlexGrid for WinForms中的数据进行一些特殊的排序操作,比如:只对指定区域的单元格数据进行排序,C1FlexGrid虽然没有内置这样的功能,不过我们可以通过自定义排序来实现该需求

发布于 2012/11/16 00:00

ComponentOne Enterprise

在某些特殊情况下,用户需要对C1FlexGrid for WinForms中的数据进行一些特殊的排序操作,比如:只对指定区域的单元格数据进行排序,C1FlexGrid虽然没有内置这样的功能,不过我们可以通过自定义排序来实现该需求。


首先,在Form中添加一个按钮和C1FlexGrid控件,并为按钮添加Click事件,添加以下逻辑:

1、得到C1Flexgrid中选中的单元格区域

C1.Win.C1FlexGrid.CellRange cr = this.c1FlexGrid1.Selection;
复制代码

2、创建一个临时的C1Flexgrid对象

var fg = new C1.Win.C1FlexGrid.C1FlexGrid();
复制代码

3、根据选中单元格的范围,为临时的C1Flexgrid指定行列数

fg.Cols.Count = cr.c2 - cr.c1 + 1;
    fg.Cols.Fixed = 0;
    fg.Rows.Count = cr.r2 - cr.r1 + 1;
    fg.Rows.Fixed = 0;
复制代码

4、给临时C1Flexgrid单元格赋值

for (int i = cr.r1; i <= cr.r2; i++)
    {
        for (int j = cr.c1; j <= cr.c2; j++)
        {
            fg[_row, _col] = this.c1FlexGrid1[i, j];
            _col += 1;
        }
        _row += 1;
        _col = 0;
    }
复制代码

5、对临时C1Flexgrid进行排序

fg.Sort(C1.Win.C1FlexGrid.SortFlags.Ascending, 0);
复制代码

6、将临时C1Flexgrid中的值设置给原始的C1Flexgrid

for (int i = cr.r1; i <= cr.r2; i++)
    {
        for (int j = cr.c1; j <= cr.c2; j++)
        {
            this.c1FlexGrid1[i, j] = fg[_row, _col];
            _col += 1;
        }
        _row += 1;
        _col = 0;
    }

关于葡萄城

葡萄城是专业的软件开发技术和低代码平台提供商,以“赋能开发者”为使命,致力于通过表格控件、低代码和BI等各类软件开发工具和服务,一站式满足开发者需求,帮助企业提升开发效率并创新开发模式。葡萄城开发技术始于1980年,40余年来始终聚焦软件开发技术,有深厚的技术积累和丰富的产品线。是业界能够同时赋能软件开发和低代码开发的企业。凭借过硬的产品能力、活跃的用户社区和丰富的伙伴生态,与超过3000家合作伙伴紧密合作,产品广泛应用于信息和软件服务、制造、交通运输、建筑、金融、能源、教育、公共管理等支柱产业。

相关产品
推荐相关案例
关注微信
葡萄城社区二维码

关注“葡萄城社区”

活字格低代码二维码

关注“活字格低代码”

想了解更多信息,请联系我们, 随时掌握技术资源和产品动态